// 发表评论组件
import React from 'react';
// 导入图片
import avatar from '../avatar.jpg';

export class Forms extends React.Component {
  constructor() {
    super();
    this.state = {
      txt: '',
    };
    // dom 容器
    this.txtRef = React.createRef();
  }

  // 设置输入状态数据
  handleTxt = (e) => {
    this.setState({
      txt: e.target.value,
    });
  };

  // 发表评论的事件处理函数
  handleAdd = () => {
    if (!this.state.txt.trim()) return this.txtRef.current.focus();

    // 传值给父组件
    this.props.addComment(this.state.txt);
    // 清空输入
    this.setState({
      txt: '',
    });

    // 体验优化
    this.txtRef.current.focus();
  };
  render() {
    return (
      // 发表评论区
      <div className="comment-send-container">
        <div>
          <img className="user-head" src={avatar} alt="头像" />
        </div>
        <div className="comment-send">
          <div className="textarea-container">
            <textarea
              cols="80"
              rows="5"
              placeholder="发条友善的评论"
              className="ipt-txt"
              value={this.state.txt}
              onChange={this.handleTxt}
              ref={this.txtRef}
            />
            <button className="comment-submit" onClick={this.handleAdd}>
              发表评论
            </button>
          </div>
        </div>
      </div>
    );
  }
}

export default Forms;
